<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        #container {
            width: 200px;
            height: 200px;
            border: 1px solid black;
            overflow: auto;
            position: relative;
        }

        #header {
            height: 100px;
            background-color: red;
            width: inherit;
        }
    </style>
</head>

<body>
    <div id="container">
        <div id="header">
            固定的头部
        </div>
        <div id="inner">
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
            你好 <br>
        </div>
    </div>
    <script>
        // 选中要吸顶的盒子
        const headerEle = document.getElementById("header")
        // 获取盒子的距离
        const _headerTop = headerEle.offsetTop
        const _container = document.getElementById("container")
        // 监听事件
        _container.onscroll = () => {
            const _scrollTop = _container.scrollTop
            console.log(_scrollTop, _headerTop)
            // 距离比较
            if (_scrollTop >= _headerTop) {
                headerEle.style.position = "fixed"
                headerEle.style.top = 0
                headerEle.style.left = 0
            }
        }
    </script>
</body>

</html>